<template>
    <Select
        class="transfer-select"
        @on-open-change="transferRefresh"
        @on-change="dataChange"
        v-model="dataRight"
        :style="{width:width}"
        :disabled="disabled || readonly"
        :placeholder="placeholder"
        multiple>
        <Option class="hidden" :value="item" v-for="(item,i) in dataRight" :key="i">
            {{findLabel(item)}}
        </Option>
        <el-transfer
            v-model="dataRight"
            :data="dataLeft"
            @change="dataChange"
            :titles="titles"/>
    </Select>
</template>

<script lang="ts">
import { Vue, Component, Prop, Model } from "vue-property-decorator";
import {CodeListService} from '@ibizstudio/runtime';
import { LogUtil } from '@ibizstudio/runtime';

@Component({})
export default class AppTransfer extends Vue {
    /**
     * 传入表单数据
     *
     * @type {*}
     * @memberof AppTransfer
     */
    @Prop() data:any;

    /**
     * 穿梭框宽度
     * 
     * @type {string}
     * @memberof AppTransfer
     */
    @Prop() width?: string;

    /**
     * 表单传入字符串值分隔符
     * 
     * @type {string}
     * @memberof AppTransfer
     */
    @Prop() valueSeparator?: string;

    /**
     * 代码表标识
     *
     * @type {string}
     * @memberof AppTransfer
     */
    @Prop() tag?: string;

    /**
     * 代码表类型
     *
     * @type {string}
     * @memberof AppTransfer
     */
    @Prop() codelistType?: string;

    /**
     * 局部上下文导航参数
     *
     * @type {*}
     * @memberof AppTransfer
     */
    @Prop() localContext!: any;

    /**
     * 局部导航参数
     *
     * @type {*}
     * @memberof AppTransfer
     */
    @Prop() localParam!: any;

    /**
     * 视图上下文
     *
     * @type {*}
     * @memberof AppAutocomplete
     */
    @Prop() context!: any;

    /**
     * 视图参数
     *
     * @type {*}
     * @memberof AppFormDRUIPart
     */
    @Prop() viewparams!: any;

    /**
     * 是否禁用
     * 
     * @type {any}
     * @memberof AppTransfer
     *
     */
    @Prop() disabled?: any;

	/**
     * 只读模式
     * 
     * @type {boolean}
     */
    @Prop({default: false}) readonly?: boolean;

    /**
     * 穿梭框提示内容
     * 
     * @type {string}
     * @memberof AppTransfer
     */
    @Prop() placeholder?: string;

    /**
     * 代码表
     *
     * @type {string}
     * @memberof AppTransfer
     */    
    @Prop() codeList!: any;

    /**
     * 当前选中值
     * 
     * @type {any}
     * @memberof AppTransfer
     */
    @Model("change") itemValue!: any;

    /**
     * 左右侧标题
     * @type{Array<string>}
     * @memberof AppTransfer
     */
    titles?: Array<string>;

    /**
     * 左侧框数据
     * 
     * @memberof AppTransfer
     */
    dataLeft: any[] = [];

    /**
     * 右侧框数据
     * 
     * @memberof AppTransfer
     */
    dataRight: any[] = [];

    /**
     * 代码表服务对象
     *
     * @type {CodeListService}
     * @memberof AppTransfer
     */
    codeListService: CodeListService = new CodeListService({
        $store: this.$store
    });

    /**
     * vue  生命周期
     * @memberof AppTransfer
     */
    created() {
        this.loadData();
        this.titles= [(this.$t('components.apptransfer.title1') as string),(this.$t('components.apptransfer.title2') as string)];
    }

    /**
     * 数据处理
     * 
     * @memberof AppTransfer
     */
    loadData() {
        if(this.tag && this.codelistType) {
            let data: any = {};
            this.handlePublicParams(data);
            // 参数处理
            let context = data.context;
            let viewparam = data.param;
            this.codeListService.getDataItems({ tag: this.tag, type: this.codelistType,data: this.codeList,context:context,viewparam:viewparam}).then((codelistItems: Array<any>) => {
                this.dataLeft = codelistItems;
                this.initData()
            }).catch((error: any) => {
                LogUtil.log(`----${this.tag}----${this.$t('app.commonwords.codenotexist')}`);
            })
        }
    }

    /**
     * 公共参数处理
     *
     * @param {*} arg
     * @returns
     * @memberof AppTransfer
     */
    handlePublicParams(arg: any) {
        // 合并表单参数
        arg.param = this.viewparams? JSON.parse(JSON.stringify(this.viewparams)): {};
        arg.context = this.context ? JSON.parse(JSON.stringify(this.context)) : {};
        // 附加参数处理
        if (this.localContext && Object.keys(this.localContext).length > 0) {
            let _context = this.$util.computedNavData(this.data,arg.context,arg.param,this.localContext);
            Object.assign(arg.context, _context);
        }
        if (this.localParam && Object.keys(this.localParam).length > 0) {
            let _param = this.$util.computedNavData(this.data,arg.context,arg.param,this.localParam);
            Object.assign(arg.param, _param);
        }
    }

    /**
     * 初始化获取到的选项数据
     * 
     * @memberof AppTransfer
     */
    initData(){
        // 初始化左侧框数据
        let left: any[] = [];
        Object.assign(left, this.dataLeft);
        this.dataLeft = [];
        left.forEach((elem: any, i: any) => {
            this.dataLeft.push({
                key: elem.id,
                value: elem.value,
                label: elem.text,
                disabled: elem.disabled
            });
        });

        // 初始化右侧框数据
        let _valueSeparator: any;
        _valueSeparator = this.initValueSeparator();
        let _data: any = this.itemValue;
        if (_data) {
        let _dataRight: any = [];
        let newData: any[] = _data.split(`${_valueSeparator}`);
        this.dataLeft.forEach((elem: any) => {
            newData.forEach((item: any) => {
                if (item === elem.value) {
                    _dataRight.push(elem.key);
                }
            });
        });
        this.dataRight = _dataRight;
        }
    }

    /**
     * 组件change事件,右侧框数据变化时
     * @memberof AppTransfer
     */
    dataChange(e: any) {
        let _valueSeparator: string;
        _valueSeparator = this.initValueSeparator();
        let newVal: string = e.join(`${_valueSeparator}`);
        if (newVal) {
            this.$emit("change", newVal);
        } else {
            this.$emit("change", null);
        }
    }

    /**
     * 初始化valueSeparator
     * @memberof AppTransfer
     */
    initValueSeparator() {
        return this.valueSeparator ? this.valueSeparator : ",";
    }

    /**
     * 穿梭框打开时刷新数据
     * @memberof AppTransfer
     */
    transferRefresh(e: boolean) {
        if (e && this.codelistType === "DYNAMIC") {
            this.dataLeft = [];
            this.loadData();
        }
    }

    /**
     * 找到dataLeft中key与dataRight中item相等的元素，返回label
     * @memberof AppTransfer
     */
    findLabel(item: any) {
        for (const elem of this.dataLeft) {
            if (elem.key === item) return elem.label;
        }
    }
}
</script>

<style lang='less'>
@import "./app-transfer.less";
</style>